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(57) Abstract: A sysiem is provided for allowing access to a library of spatial algoriiKms and access to other conunon resources for 
supporting the development and implemencaiion of multiple location based services applications. In one embodiment, a multilayered 
architecture (800) is employed. The architecture (800) includes an applications layer (802), a middle ware layer (804) and a core class 
libraries layer (806). The application in the applications layer (802) can call or access the components in the middleware layer (804) 
to implement specific functions, and the middleware components can access libraries of the core class layer (806) to implement such 
functions. Common resources can thus be used to support multiple applications, even though those applications may have different 
objectives and different requirements regarding location data. 
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SPATIAL TOOLKITS FOR WIRELESS LOCATION BASED SERVICES 
FIELD OF THE INVENTION 
The present invention relates in general to the provisioning of location based 
5 services in a wireless networic, e.g., a network for analog or digital voice, video and/or 
data communications including a wireless telephone, pager, data temiinat or other 
wireless unit. In particular, the present invention relates to the provisioning of spatial 
algorithms and related information for use in locating a wireless unit within the network 
and/or relating a wireless unit location to a service zone of a wireless location service 
10 provider. 

BACKGROUND OF THE INVENTION 
A variety oflocation based semces applications have been proposed. Generally, 
these applications involve providing services to a wireless network subscriber, or 
15 recording business or other information relating to services accessed or otherwise used 
by a wireless network subscriber, based on a location of the wireless unit. In this regard, 
the location of the wireless unit maybe deteraiined based on knowledge of the cell sector 
or other subdivision of the network where the wireless unit is located, or based on 
information obtained from location finding equipment. Accordingly, the location of the 
wireless unit may be deteimiried to varying accuracies depending on the nature of 
location technology employed, and may be expressed in terms of geographic coordinates, 
uncertainty regions and/or wireless network or other zone areas. 

Examples of proposed location based service applications include location-based 
billing, 91 1 call routing and local traffic or service information. In location based billing 
applications, a wireless subscriber is billed for calls within a wireless network depending 
on the location of the call. For example, a subscriber may be billed a lower rate for calls 
placed from a home, office or other defined location, or a subscriber may be billed for 
calls based on network area codes or the like. In 911 call routing applications, the 
location of a wireless unit placing an emergency call is matched to an emergency network 
dispatcher zone so that the call can be properly routed to facilitate a rapid emergency 
response. ]n local traffic or service infonnation applications, a wireless subscriber can 
receive information regarding local traffic conditions and/or food, lodging or other 
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services, based on the location of the subscriber's wireless unit. Many other types of 
wireless location service applications are possible. 

Each of these applications involves comparing a wireless unit location to a service 
location, e.g., the location of a service provider or service zone. However, the nature of 
5 the location determination may vary depending on the objectives of the s^plication and 
other factors. For example, in location-based billing or 91 1 call routing applications, the 
location detemiination may involve determining whether a wireless unit is in or out of 
a service zone such as a home zone, area code region or other billing zone (e.g., in the 
case of location-based billing applications) or particular dispatcher zones (e.g., in the case 
10 of91 1 callrouting). In local service applications, the location determination may involve 
identifying the closest service provider for a given type of services. 

Due to the varying nature of location-based service application objectives and 
attendant location determination methodologies, application developers have often 
designed or envisioned custom location determination algorithms. Thus, for example, 
1 5 the geographic coordinates of dispatcher zones may be stored in a look-up table or other 
data structure, such that the location of a wireless unit can be compared to such zones for 
emergency call routing. In at least one case, it has been proposed to define home billing 
areas by reference to a circle of defined radius centered at a subscriber home location, so 
that call rating can be based on a detemiination of whether the call is inside or outside of 
20 circular home billing area boundaries, hi other cases, the location determination may 
involve comparing a wireless unit location to the locations of various service providers 
by way of distance determinations and/or related calculations to find the closest service 
provider or the service provider that can be reached in the least amount of dnving 
distance or time. Customized algorithms have been designed or envisioned for each such 
25 application. 

It will be appreciated that developing custom algorithms on an application-by- 
application basis is a complicated and time consuming process which delays and adds to 
the expense of development of new location based services applications. Moreover, the 
operation of such algorithms with respect to stored databases of location information can 
30 be problematic. In this regard, it will be appreciated that the relevant location 
information may change from time-to-time. For example, network geometry may change 
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due to the addition of cell site equipment to increase capacity or overall sen^ice area, or 
service provider zones may change for various reasons. As a result, significant revision 
of databases may be required so that the spatial algorithms can yield useful infonnation. 
Such revision of databases, in turn, may result in significant system down time or deter 
5 development and/or full implementation of data intensive applications such as location- 
based billing employing subscriber specific home zones. 
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SUMMARY OF THE INVENTION 
It has been recognized that various types of location based applications share or 
can be designed to share similar location detemiination characteristics. For example, 
various types of applications involve comparing a wireless unit location to service zones 
or making a distance detennination relating to a wireless unit location and a service 
provider location. It has also been recognized that storing location infom^ation in tenns 
of network or service area geometries which may change is inefficient for certain 
applications. Accordingly, the present invention provides certain toolkits and libraries 
including spatial algorithms for facilitating development and deployment of a variety of 
location based service applications. In addition, the present invention provides a 

mechanism forefficientlyprovisioningandre-provisioningnetworkorotherservicezone 
geometries such that location determinations can be based on cun-ent service zone 
geometry without requiring substantial manual database revision. The invention thereby 
facilitates efficient location based service application development, deployment and 
maintenance. 

According to one aspect of the present invention, a method is provided for 
provisioning wireless unit related infonnation using a libraiy of spatial algorithms. The 
library includes a number of spatial algorithm tools where each tool is useful for 
performinga location comparison between first and second geographic information. The 
geographic information can be coordinates, uncertamty regions and/or other areas. Each 
of the tools implements at least one type of spatial algonthm such as an overlap 
companson algorithm (e.g., point-m-polygon, circle overlap, etc.) and/or a time/distance 
comparison algorithm (e.g., closest service point algorithm) such that the resulting toolkit 
provides at least two different spatial algorithms. The associated method includes the 



-3- 



wo 01/33825 



PCT/USOO/30479 



stq>s of: accessing the sparial algorithm library; selecting one of the spatial algorithm 
tools from the library, storing service information defining service locations relative to 
geographic information; obtaining input location information regarding the location of 
a wireless unit based on signals transmitted within the wireless network; using the 
5 selected spatial algorithm relative to the stored service information and obtained input 
location information to identify a service location for the wireless unit; and using the 
identified service location for one of providing services and recording business 
infomiation concerning the wireless unit. 

The library may be accessed, for example, prior to implementation of a wireless 

1 0 location services application (such as during apphcation development), during application 
execution (such as upon receiving wireless unit location information) and/or in response 
to a location request from a wireless location services application or user. The tool is 
preferably selected based on the nature of the subject location determination. For 
example, a point-in-polygon or other overlap comparison algorithm may be selected for 

15 a service zone identification application (e.g., emergency call routing or location based 
billing) whereas a time/distance comparison algorithm may be employed for a local 
traffic/services application. The stored service information may include geographic 
coordinates (e.g., the latitude and longitude of service providers), polygon or other area 
boundaries (e.g., defining emergency dispatch zones) or other area information (e.g., the 

20 geographic location corresponding to a network cell sector). 

The input location information can vary depending, for example, on the 
localization technology or technologies employed. In this regard a variety of location 
finding equipment (LFE) technologies and area localization technologies are possible. 
Such LFE technologies include GPS based systems and triangulaiion systems such as 

25 angle of arrival systems that determine location based on the angle of arrival of signals 
at a wireless unit and/or cell site or other antennae. Area localization technologies 
include cell sector systems where the wireless unit location is approximated based on the 
cell sector handling wireless unit conununications. In addition, the input location 
information may include information obtained by combining multiple inputs from the 

30 same or separate LFEs and/'or area localization systems. The selected spatial algorithm 
may be used to identify a service zone where the wireless unit is located, to identify local 
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services, or otherwise to identify a service location. This service location can then be 
used for any of various location based service application objectives such as recording 
a billing zone or rate for a call or routing an emergency call. 

According to another aspect of the present invention, a geographic information 
5 system (GIS) application is used to provision location infomiation in a wireless network. 
The GIS application is operative for correlating geographic coordinate infoimation with 
network information such as street address information, street network topology, and 
service zone maps. The associated method includes the steps of: providing a location 
based services application for execution on a platform associated with said wireless 
network; providing a GIS appUcation; receiving input information regarding a geographic 
locale (such as a cell sector, street address or service zone) for use by the location based 
services application in making service related determinations; employing the GIS 
application to provide processed location information for use by the location based 
service application based on the input information; and employing the location based 
service application to make service related determinations using the processed location 
information provided by the GIS application, hi this manner, the GIS application is used 
for provisioning location information in a form that can be readily handled by a wireless 
location-based services application in an On-Line Transaction Processing (OLTP) 
environment. 

According to a further aspect of the present invention, wireless unit location 
infomiation and service location information is stored as geographic information and one 
or both is interpreted as current topological information as required for location 
determinations. Thus, each of the wireless unit location information and service 
information can be stored, for example, as geographic coordinates defining a point and/or 
geographic infomiation defining an uncertainty region, a service zone or a service 
boundary. When making a location determination, the geographic information can be 
interpreted, for example, in terms of a network geometiy (e.g., a cell sector location), 
"pixels" or grid elements of a quadtree system, a sei^ice area (e.g., a billing zone or rate 
zone) or other reference geometry, hi this manner, location information is stored 
independent of network subdivisions, service area or other service locations that may 
change from time-to-time. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
For a more complete understanding of the present invention and further 
advantages thereof, reference is now made to the following detailed description taken in 
conjunction with the drawings in which: 
5 Fig. 1 illustrates a cell stmcture of a wireless network in which the present 

invention may operate; 

Fig. 2 illustrates a processor system for use in implementing the present invention; 
Fig. 3 illustrates a wireless network for implementing a subscriber delivered 
scr\'ice information ^plication in accordance with the present invention; 
10 ■ Fig. 4 illustrates a wireless network using multiple LFEs in accordance with the 

present invention; 

Figs. 5 A-5E illustrate various spatial algorithms in accordance with the present 
invention; 

Fig. 6 is a flowchart illustrating a process for use in providing driving instructions 
1 5 in accordance with the present invention; 

Fig. 7 is a flowchart illustrating a process for using GIS data for processing 
location information in an OLTP envirormient in accordance with the present invention;. 

Fig. 8 illustrates a layered architecture for implementing location based services 
in accordance with the present invention; 
20 Fig. 9 is a flowchart illustrating a process for developing a location based services 

application using the architecture of Fig. 8; and 

Fig. 1 0 illustrates a process for implementing a location based services application 
using the architecture of Fig. 8. 

25 DETAILED DESCRIPTION 

In the description below, the invention is set forth in the context of various 
location based service applications. Many such applications have been proposed and 
various aspects of the invention are broadly applicable to a broad range of such services. 
Accordingly, it will be appreciated that the invention is not limited to the various 

30 exemplary applications descnbed below. 
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An important aspect of the present invention relates to facilitating the 
development and maintenance of various types of location based service applications for 
wireless networics as well as enhancing the functionality of such applications, for 
example, by allowing access to GIS information on a in an OLTP environment. The 
5 present invention is based, in part, on the recognition of problems that potentially arise 
in the wireless environment (e.g., due to changing network boundaries), the recognition 
of the varying nature of the location information that may be available in a wireless 
environment or the types of location determinations that may be required, and the 
recognition of the value of accessing GIS bywireiess location-based services applications 
operating in an OLTP environment. For a better understanding of the invention and its 
advantages in the wireless network context, the followmg description includes 1) a 
description of an exemplary wireless networic; 2) a description of various types of 
location finding technologies; 3) a description of various types of location based services 
applications; 4) a description of various spatial algorithms for use in deriving location 
15 information; and 5) a description of a layered architecture and various toolkits for 
supporting numerous location based services applications based on a number of generic 
tools. 
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1- Wireless Network Environment 

The present invention is directed to the provision of location information in a 
wireless network, e.g., the determination of whether a location associated with a wireless 
station is within a particular area of interest. The noted determination is of particular use 
with respect to cellular telephones (e.g., analog, digital and PCS). While the invention 
will be described with respect to a wireless telephone, it should be understood that the 
invention can be used to make the noted determination with any type of wireless unit, 
provided a location can be associated with the wireless unit. 

Referring to Fig. 1 , the basic components of a wireless telephone system 1 20 are 
illustrated. The wireless telephone system 120 operates to establish telephone 
connections for wireless telephones within a service area 122. The service area 122 is 
30 sub-divided into cells 124A-1 24C that respectively include base stations 1 26A- 126C for 
relaying communications to and from wireless telephones 128 located in the cell. Each 
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of the base stations 1 26A-1 26C is in communication with a switch 1 30 such as a mobile 
switching center ("MSC") 1 30 that operates to establish a connection between a wireless 
telephone in the service area 122 and another telephone device. If the other telephone 
device is not another wireless telephone in the service area 122, the switch 130 
5 commimicates via an external communication path 132 with the appropriate switching 
stations to establish the connection. For instance, if the other telephone device is a 
conventional land line telephone, the switch 130 uses the external communication path 
132 to communicate with the switching station that services the land line telephone to 
establish the communication channel. In operation, the base station associated with the 

1 0 wireless telephone 128 that is attempting to place a call or to receive a call and the switch 
30 cooperate to establish a communication channel between the wireless telephone and 
the other telephone device. Once the communication channel is established, 
communications can occur between the wireless telephone and the other telephone device 
for as long as the wireless telephone remains in the service area 122 or, in the case of 

15 roaming service, another service area 122. A platform 134 associated with the switch 
1 30 is operative for supporting a variety of service applications including location based 
service applications, or tools for use by external location based service applications, as 
will be described below. 

Referring to Fig. 2, the determination of whether the location associated with 

20 wireless telephone is within an area of interest is implemented on a computer system that 
may be resident at platform 1 34 (Fig. I ). The computer system includes a processor 238, 
memory 240 and input/output port 242. The processor 238 executes a program that 
makes use of certain spatial algorithms as described below to determine whether a 
location associated with a wireless telephone is within a predetermined area of interest 

25 or to otherwise access/provide services based on the location of the wireless telephone. 
During this determination at least a portion of the program and at least a portion of the 
spatial algorithm tool are located in the memory 240. The location associated with the 
wireless telephone is provided to the input side of the port 242. The determination of 
whether the location associated with the wireless telephone is within a particular area of 

30 interest is made by a program by the processor 238 and resulting service information or 
other information depending on the application is provided to the output portion of the 
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port 242. A disk drive 244 is an optional element of the system 236 that can be used to 
store a portion of the program executed by the processor 238 and load the portion of the 

program intomemoo.240whenneeded. All oraportionofthespatial algorithm toolcan 
also be storedon the disk drive244andloadedintomemoo^whenneededinan operation 
known as cachmg. Cachmg pennits portions of the spatial algorithm tool to be loaded 
mto memo^ when needed rather than having to retain the entire tool and associated data 
stnicture in the memory 240. This is particularly useful if there are constraints on the use 
ofthe memory 240. For mstance. the size ofthe memory may be limited. Thecomputer 
system 236 also optionally includes other peripherals, such as keyboards and monitors, 
that may be useful in executing and/or monitoring the program. 

For certain wireless location services applications, service information is 
transmitted to a user or subscriber based on the location of a wireless telephone. Fig. 3 
illustrates a wireless telecommunications network 300 for implementing such 
applications. Although not shown, tire network 300 is divided into a number of service 
areas or cell as described above. Each cell includes cell site equipment 308 for receiving 
RF signals from wireless telephones 302 of network subscribers and transmitting RF 
signals to the wireless telephones 302. The cell site equipment 308 of multiple cells are 
.n turn, comiected to an switch 310 typically by wireline comiections. Among othe^ 
things, the switch 310, as described above, is used m establishing voice chamiels for 
communication between the calling and called phones. The switch also provides 
information for generating call detail records or other billing records. 

hi connection with tiie switch 310, one or more platfomis 312 are generally 
provided for implementing a variety of subscriber or network service functions. For 
example, the platform 312 may implement an application for routing calls based on 
subscriber data, hi the illustrated embodiment, the platform 3 12 is used to mn logic for 
implementing a location based services application whereby service information is 
delivered to a subscriber based on the location ofthe telephone 302. 

The illustrated netN^'ork 300 also includes a data server 320 associated with the 
platform 312 and the switch 310. The data server 320 provides an interface by which 
information can be communicated between the platform 312 and subscribers or third 
parties. The data sender 320 may also receive signals from the switch 310 such as call 
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start signals, call stop signals and the like. that may be transmitted to billing systems or 
other applications. As shown, the data server 320 receives an input from the platfonn 
312 that may include location-based service information to be transmitted to the 
subscriber or third parties. In the case of location-based service infonnation (such as the 
5 location of a local service provider or a menu of service providers) to be transmitted to 
the subscriber, such information is communicated to the subscriber via the switch 310 
and cell site equipment 308. More specifically, upon receiving a service request, the 
switch may transmit service request information to an application associated with 
platform 312, The application responds, with call routing infomiation that prompts the 
10 switch 310 to establish a communication channel between the phone 302 and the data 
server 320. This channel is then used to communicate the location-based service 
information from the data server 320 to the phone 302 for audible or visual presentation 
to the subscriber. The data server 320 may also or alternatively be used to transmit data 
to third parties such as an identified service provider 324. For example, upon 
1 5 identification of the service provider 324 based on the subscriber's service request, the 
subscriber may request a direct voice connection to the service provider 324 or may 
request that financial information or other data be transmitted to the service provider 324 
to process a service transaction. In this regard, an appropriate voice and/or data link 322 
may be established between the data server 320 or the switch 310 and the service 
20 provider 324 via the network 300 and/or a further network such as the Internet. It will 
thus be appreciated that the interactive location-based service process of the present 
invention may involve a series of communications with the phone 302. 

The illustrated phone 102 is an enhanced phone, i.e., a phone adapted for voice 
and data communication with a built-in processor. The phone includes a conventional 
25 keypad 306, a roller ball, arrow keys, touchpad or other data input device 304, and a 
screen 305 for displaying data. In this manner, the subscriber can enter service requests 
via the keypad 306 or data input device 304, and can receive service information audibly 
or via the display 305. Additional elements of the system 300 are described below in 
connection with panicular applications for delivering service infonnation to a subscriber. 

30 
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2- Location F inding TenhnnU^ ^ 

As noted above, many difTerent location finding technologies are available, some 
of which include dedicated LFE's. The present invention supports applications that can 
utilize any of various location finding technologies or combinations thereof. 
5 Referring to Figure 4, a wireless telecommunications network including multiple 

LFEs is generally identified by the reference numeral 400. Generally, the network 
includes a switch 412, such as described above, for use in routing wireless 
communications to or from wireless stations402,anetworkplatfonn 414 associated with 
the switch 412 for implementing a variety of subscriber or network service functions, and 
a variety of LFE and/or area localization systems 404, 406, 408 and 410. In the 
illustrated embodiment, the network platform is used to run a Location Manager (LM) 
416 in accordance with the present invention, a GIS application 420 and a number of 

wirelesslocationapplications418. Although the illustrated LM416,GISappIication420 
and wireless location applications 418 are illustrated as being resident on the network 
platform 414, it will be appreciated that the elements 416 and 418 may be located 
elsewhere in the network 400, may be resident on separate platforms, or the functionality 
of each of these elements 416 and 418 may be spread over multiple platforms. In 
addition, other applications not depicted in Figure 4 may be resident on the platform 414. 

20 As shown in Figure 4, multiple LFE systems 404, 406. 408 and cell/sector system 

4 1 0 may be associated with the network 400. These systems 404, 406, 408 and 4 1 0 may 
employ any of a variety of location finding technologies such as angle of arrival (AOA). 
time difference of arrival (TDOA), Global Positioning System ( GPS) and cell/sector 
technologies and the various systems 404. 406 and 408 may be the same as or different 

25 firom one another. It will be appreciated that the nature of the data obtained from the 
systems 404, 406, 408 and 410 as well as the path by which the data is transmitted varies 
depending on the type of LFE employed, and the ability to accommodate a variety of 
LFEs is an important advantage of the present invention. Some types of LFEs include 
LFE equipment in the handset. Examples include certain GPS and TDOA systems. In 

30 such cases, location information may be encoded into signals transmitted from the 
handset to a cell site or other receiver, and the information may then be transferred to the 
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platform 414 via the switch 412 or otherwise. Other LFE systems, i.e., embedded 
systems, use equipment associated with individual cell sites such as specialized antennae 
to make location detemiinations such as by triangulation and, again, the resulting location 
information may be transferred to the platform 414 via the switch 412 or otherwise. Still 

5 other LFE systems employ a network of dedicated LFE equipment that is overlayed 
relative to the wireless network. Such systems may communicate location infomiation 
to the platform 414 independent of the switch 412 and network cell site equipment. In 
addition, some LFE technologies can be implemented via equipment resident in the 
handset, in cell sites or other network locations and/or in dedicated LFE sites such that 

1 0 the data pathway of the location information may vary even for a given LFE technology- 
Three of the illustrated systems 404, 406 and 408 operate separate from the switch 
412. For example, such systems may include network based systems such as AO A and 
TDOA systems and external systems such as GPS. Generally, the illustrated network 
based systems determine the location of a wireless station 402 based on communications 

15 between the wireless station and the cell site equipment of multiple cell sites. For 
example, and as will be described in more detail below, such systems may receive 
information concerning a directional bearing of the wireless station 402 or a distance of 
the wireless station 402 relative to each of multiple cell sites. Based on such information, 
the location of the wireless station 402 can be determined by triangulation or similar 

20 geometric/mathematic techniques. External systems such as GPS systems, determine the 
wireless station location relative to an external system. In the case of GPS systems, the 
wireless station 402 is typically provided with a GPS receiver for determining geographic 
position relative to the GPS satellite constellation. This location information is then 
transmitted across an air interface to the network 400. 

25 The illustrated cell sector system 410 may be associated with cell site equipment 

for communicating with the wireless station 402, In this regard, the cell site equipment 
may include three or more directional antennas for communicating with wireless stations 
within subsections of the cell area. These directional antennas can be used to identify the 
subsection of a cell where the wireless station 402 is located. In addition, ranging 

30 information obtained from signal timing information may be obtained to identify a radius 
range from the cell site equipment where the wireless station 402 is located, thereby 
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10 



yielding a wireless station location in tenns of a range of angles and a range of radii 
relative to the cell site equipment. This cell/sector location information can be 
transmitted to the LM 416 via the switch 412 or possibly via other network inforaiation 
or structure. 

As shown, the LM 416 receives location information from the various LFE 
systems 404, 406, 408 and 410. The nature of such information and handling of such 
information is described in more detail in U.S. Patent AppUcation Serial No. 60/106,8 1 6 
entitled "Data Fusion For Wireless Location-Based AppUcations," and U-S. Patent 

Application Serial No. , which are incorporated herein by reference. Generally, 

however, such infonnation is processed by the LM 416 to provide location outputs for 
use by any of various wireless location applications 41 8 in response to location requests 
from the application 418. Such applications may include any wireless location services 
applications such as 9 1 1 , vehicle tracking and location-based billing programs. The GIS 
application may interface with the LM 41 6 or applications 41 8 to associate geographic 
1 5 coordinate infonnation with mapping information and vice versa. 

A number of different location finding technologies are depicted in Figures 5 A- 
5D for purposes of illustration. Figure 5A generally shows the coverage area 500 of a 
cell sector. As noted above, the cell site equipment for a particular cell of a wireless 
telecommunications system may include a number, e.g,, three or more, of directional 
antennas. Each antenna thus covers an angular range relative to the cell site bounded by 
sides 502. hi the case of a three sector cell, each antenna may cover about 120° - 150° 
relative to the cell site, hi addition the coverage range for the antenna defines an outer 
perimeter 504 of the coverage area 500. As shown, the range varies with respect to angle 
defining a somewhat jagged outer perimeter 504. Accordingly, the actual uncertainty 
25 regarding the location of a wireless station located in the illustrated cell sector is defined 
by the coverage area 500. The location determination output from a cell/sector LFE is 
therefore effectively defined by the coordinates of the coverage area 500. 

Figure 5B depicts a TOA based LFE. hi this case, the wireless station's range 
from a cell sector antenna is determined, based on time of signal arrival or signal transit 
30 time to within a radius range, e.g., about 1 000 meters. Accordingly, the wireless station's 
location can be determined to be within an area bounded by sides 506 (based on the 
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angular range of the cell sector antenna) and inner 508 and outer 5 1 0 arcs (defined by the 
ranging uncertainty). The output from a TOA based LFE is effectively defined by the 
coordinates of the sides 506 and the axes 508 and 510. 

An AOA based LFE is generally illustrated in Figure 5C. AOA based LFEs 
5 determine the location of a wireless station based on the angle of arrival of signals, 
generally indicated by rays 512 and 514, from the wireless station as measured by two or 
more cell sites 516 and 518. Each angle measurement has an angular uncertainty 
generally indicated by line segments 520 and 522. Consequently, the uncertainty region 
for a given location determination is defined by a polygon having 2n sides, where n is the 
10 number of cell sites 516 and 518 involved in the measurement. 

Figiure 5D illustrates a TDOA based LFE, Although the illustrated system is cell 
site based, the TDOA system may alternatively be handset based. In TDOA systems, 
multiple cell sites measure the time of arrival of signals from a wireless station. Based 
on such measurements, each cell site can provide information regarding wireless station 
15 location in terms of a hyperbola 524 or 526 and an uncertainty, generally indicated by 
segments 528 and 530. The resulting uncertainty region is defined by a multi-sided 
region (where each wall is curved) having 2n walls, where n is the number of cell sites 
involved in the detenmination. 

Figure 5E illustrates a GPS based LFE, In GPS systems, the wireless station 
20 includes a GPS transceiver for receiving signals indicating the wireless station's location 
relative to multiple satellites in the GPS constellation. Based on these signals, the 
geographic coordinates of the wireless station's location is determined to an accuracy of 
perhaps 20 meters as generally indicated by circle 532. This information is then 
transmitted to the wireless network across an air interface. 
25 As described in copending appHcation Serial Nos. 60/106,816 and 09/396,235, 

the LM can receive location requests from various applications, query or otherwise obtain 
location information from one or more LFEs, and provide location outputs to the 
applications. Such outputs may be based on a single LFE input or combinations thereof. 
To facilitate such servicing of multiple applications by multiple LFEs, the LM utilizes 
30 a standardized data format and standardized communications protocols thereby defining 



-14- 



wo 01/33825 

PCTAJSOO/30479 

a common logical platfonn for a variety location based services applications such as 
described below. 



10 



15 



3- Location Based Service Applications 

Many different types of location based services applications have been 
implemented or proposed. The nature of the location based service application and other 
factors may determine what type of spatial algorithm is required. Acconiingly, a number 
of different types of location based services applications will now be described to provide 
a better understanding of the preset invention. 

A number of location based services applications involve detennining, whether 
a mobile unit such as a wireless telephone is located within an area of interest. Examples 
of these applications include emergency or "91 1" applications, location dependent call 
billing, cell-to-cell handoff, vehicle tracking and local service infonnation applications. 
In 91 1 applications, the location of a wireless station is detemiined when the station is 
used to place an emergency call. The location is dien transmitted to a local emergency 
dispatcher to assist in responding to the call. In typical location dependent call billing 
applications, the location of a wireless station is detemiined, for example, upon placing 
or receiving a call. This location is then transmitted to a billing system that determines 
an appropriate billing value based on the location of the wireless station. For example, 
a carrier may offer a lower rate for calls that are placed from an area associated with a 
subscriber's home, office or other location. Alternatively, different rates may apply to 
calls placed or received within different area codes or other network subdivisions. In 
haridoff applications, a wireless location is determined in order to coordinate handoff of 
call handling between network cells. Vehicle tracking applications are used, for example, 
to track the location of stolen vehicles. In this regard, the location of a car phone or like 
in a stolen vehicle can be transmitted to the appropriate authorities to assist in recovering 
the vehicle. 

A particularly advantageous implementation for area of interest type applications 
is described in copending United States Patent Application entitled "Method and System 
for Dynamic Location-Based Zone Assignment for a Wireless Communication Network" 
(Serial No. not yet assigned) filed concurrently herewith which is incorporated herein by 
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reference. As described in that application, a system is provided for determining whether 
a wireless station is within an area of interest such as a home biUing zone. This 
detennination can then be reported to a billing application. The home billing zone may 
be defined for particular subscribers by reference to then existing cell sector boundaries 
5 or other communications network areas. Similarly, when a call is placed, the location of 
the call may be defined, by a cell sector system or the like, by reference to current cell 
sector boundaries or other communications network areas. 

To accommodate communications network changes without the need to manually 
re-enter data on a subscriber-by-subscriber basis, geographical data corresponding to the 

10 home billing zone may be stored rather than merely a cell sector or other network 
identifier for the home zone. At or near the time that the call is placed, this geographical 
data can be translated into current communications network information, e.g., a cell or 
cell sector identifier. The translated home zone information can then be compared to the 
corresponding location information for the call to determine if the call location is within 

15 the home zone. Importantly, even though the home zone information may have been 
recorded some length of time before the call, the call/zone comparison is conducted based 
on current network geometry. Thus, network changes do not necessitate undue re-entry 
of data. 



20 is reported to a third party, a number of applications have been proposed where service 
information is delivered to a subscriber. Such applications are described in detail in 
copending United States Patent Application Serial No. 09/1 19,493 entitled "Subscriber 
Delivered Location-Based Services" which is incorporated by reference herein in its 
entirety. These applications may be understood by reference to Fig. 3. The platform 312 

25 of Fig. 3 includes pons for accessing and receiving optional subscriber profile 
information 3 1 4, inputs 3 1 6 ft-om LFEs as discussed above, and service information 318. 
The subscriber profile information 314 may incliide information regarding individual 
subscribers that is useful in personalizing the location based services and in processing 
individual service requests. Some examples of such information include: 1) financial 

30 information for use in executing a location based service transaction \ as credit card 



numbers and expiration dates, back account numbers or corporate account information; 



In addition to applications such as discussed above where location information 
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2) service preference information such as hotel room requirements, information regarding 
discount programs or club memberships and prefeired chains or other service providers; 

3) information regarding the subscriber's service usage profiles such as typical travel 
times roads, types of services most often requested by the subscriber and demographic 

5 information; and 4) the subscriber's willingness or desire to receive complimentary 
service information and advertisements. Such profile infomiation may be entered by a 
carrier or other location based service administrator upon signing up for the seivice and 
may be periodically revised or automatically revised based on adaptive logic. 

The illustrated platform 312 also accesses and receives service information. 
10 Various types of service information may be provided for various locationbased services. 
For example, for services such as locating outlets, hotels, service stations, towing 
services, or other service providers in the vicinity of the subscriber, the service 
information may include a database of service providers indexed to coiresponding service 
locations. Such service locations may be stored in the form of latitude/longitude data, 
1 5 corresponding street address data, zip codes or other regional/seivice area indicators, or 
any other appropriate identifiers, h this regard, a GIS application may be employed to 
correlate typological infomiation (e.g., street addresses and street boundaries) to 
geographical coordinate information. For other types of services such as, for example, 
traffic or road conditions, stored infomiation for particular areas or locations may be 
20 updated on a regular basis or, alternatively, the platform 312 may be linked to an external 
source of real time or near real time information. Alternatively, as described in more 
detail below, the service information may involve stored or substantially real-time 
information regarding the location of a service provider. 

The subscriber profile infomiation 314, service information 318 and LFE 
25 information 3 1 6 or enhanced position information is used in the illustrated system to 
provide location-based service information. It will be appreciated that this location-based 
service information can, optionally, be personalized based on the subscriber profile 
information 314. For example, in the case of providing local food outlet, service station 
or hotel information, the location-based service infomiation can include not only 
30 information regarding service providers in the vicinity of the subscriber, but can also 
identify local service providers or services meeting criteria specified by the profile 
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information 314. The location-based service information may therefore identify a local 
hotel that has a four star rating and conference rooms, and that accepts credits cards and 
participates in a particular corporate discount plan, or it may identify the closest ATM 
machine that does not charge a transaction fee. 
5 In many of the above-noted applications, the location of a wireless xmit is 

compared to certain areas of interest. For example, in 91 1 applications, the location from 
which an emergency call is placed is compared to dispatcher service areas in order to 
properly route the call. In location dependent billing applications, the location of a call 
may be compared to certain billing zones of a carrier. Similarly, in certain subscriber 
1 0 delivered service information applications, the information delivered to the subscriber is 
selected based on the service area within which the wireless unit is located. For example, 
the location of a wireless unit may be compared to pizza delivery zones, towing service 
dispatch zones or the like to identify an appropriate service provider and/or route a call. 
In other cases, the location based services application is not necessarily concerned 
1 5 with determining whether the mobile unit is located within an area of interest but, rather, 
is concerned with identifying the closest service provider, the most relevant local service 
information, driving instructions to a particular location taking into account local traffic 
conditions, etc. 

It will be appreciated that different types of calculations may be required 
20 depending on the nature of the location based service application. In this regard, area of 
interest type applications involve a comparison of location information for the mobile 
unit to stored information regarding the area or areas of interest. The areas of interest 
may be of various shapes. Other applications involve a comparison of the location of the 
mobile unit to the locations of various potential service providers in order to identify the 
25 closest suitable service provider. Still other applications, such as driving instructions, 
may involve a hybrid determination considering both the distance to relevant service 
providers as well as local traffic conditions in order to identify a service provider that can 
be reached in the least amount of driving time. Accordingly, different types of spatial 
algorithms maybe employed to meet the needs of different applications. 

30 
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4- Spatial Algnrifhmg 

Based on the foregoing, it will be appreciated that various types of spatial 
algorithms may be required to support various types of appUcations. Some examples of 
types of spatial algorithms follow. 



a) Point in area 

In a variety of applications, it is desired to determine whether a wireless unit is 
within an operating zone of the application or to determine within which operating zone 
the wireless unit is located. The operating zones can be simple or complex in shape. 
Moreover, an operating zone may include multiple areas that are not contiguous. Two 
examples of point-in-area type algoridmis are provided below. 



10 



i) Point-in-Polygon. 

Point in polygon algorithms are useful in a variety of applications where it is 
15 desired to determine whether a wireless unit is within an area of interest which can be 
defined as a polygon. Such point in polygon algorithms can be implemented in many 
ways. For example, in a simple case where the polygon is rectilinear having sides that 
are oriented along particular longitudes and latitudes, a pomt in polygon detennination 
can be made by comparing the point (e.g., a latitude and longitude of a mobile unit) to 
20 the vertices of the polygon to determine whether the point is between the vertices. In 
more complicated settings, e.g., involving more complicated polygon shapes, the point 
may be mathematically compared to line segments between polygon vertices or to a 
mathematical representation of an area circumscribed by the polygon edges. 

2^ ") Point-in-Area of Arbitrary Shape 

These point in area algorithms are a generalization of the point in polygon 
algorithms described above, and are applicable to areas having straight or curved 
boundaries. Again, the point in area detemiination can be made by mathematically 
definmg the region circumscnbed by the area edges and then comparing the point at issue 

30 to the defined region. Alternatively, a line segment or ray may be defined extending, for 
example, from the point to an end of the coverage area. Conveniently, such a line 
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segment or ray may extend along a longitudinal or latitudinal line intersecting the point 
at issue. This line segment or ray can then be compared to the edges of the region to 
determine the number of intersections therebetween, e.g., by simultaneously solving the 
associated mathematical equations. Based on this comparison, the point will be 
5 determined to be inside the region if there is an odd number of intersections and outside 
if there is an even number. 

b) Circle Overlap 

Yet another type of spatial algorithm that may be used to determine whether a 

10 point may be within a region of interest are circle overlap algorithms. This type of 
algorithm is useful in accounting for uncertainties inherent in wireless location 
determinations. For example, a particular location sensitive billing program may provide 
a lower billing rate when a subscriber places calls at or near a home location, office 
location other location. Accordingly, when a subscriber places a call, the associated 

15 application may access a database of stored home zone information defining "home 
locations" of various subscribers, receive subscriber location information regarding the 
location of the subscriber, and compare the received location information to home 
location information for the subscriber to determine a billing rate or rate zone for the call. 
However, there may be uncertainties associated with the home location and subscriber 

20 location. In this regard, each of these locations may be defined based on a cell sector 
identifier or by geographic coordinates and an uncertainty. In accordance with the "circle 
overlap*' spatial algorithms, each of the home location and subscriber location may be 
defined as a circle (or other shape) defining the respective locations with due regard for 
the associated uncertainties. The resulting circles can then be mathematically compared 

25 for overlap. In the case where the circles overlap in a home zone billing application as 
described above, the call may be deemed to be within the home zone because the 
possibility that the call is within the home zone has not been eliminated. 



c) Quadtree Data Structure 
30 A quadtree data structure for use in the online transaction processing (OLTP) 

environment is disclosed in copending United States Patent Application No. 09/258,228 
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entitled "Method for Determining if the location of a Wireless Communication Device 
.s Within a Specified Area", filed Febma^ 26, 1999 and commonly assigned with the 
present application. That application is incorporated herein by reference in its entirety 
Generally, for an area of interest analysis, to detemiine whether the location associated 
5 with a wireless station is within a predetermined area of interest, the invention uses a 
"quadtree" computer data structure that represents the area of interest. The quadtree 

representationoftheareaofinterestfacilitatesiterativelyandquicklydetermininganarea 
.n which the location associated with the wireless station is situated Once this area 
(known as a quadrant) has been detemiined. the quadtree stracture further provides an 
indication of whether or not the quadrant is part of the area of interest. The quadtree data 
structure can also be updated to reflect changes in the area of interest or to add new areas 
of interest with little impact upon the telecommunication system in wh,ch the invention 
is implemented. 

The quadtree is a multi-level structure with each level representing the same 
surface area of the earth but higher levels representing the surface area with a higher 
degree of resolution. In one embodiment, the first level of the quadtree represents the 
emire surface of the earth and is conceptualized as a "square". The second level of the 
quadtree represents the four quadrants of the earth's surface, where the first quadrant 
extends firom 0° to 180° longhude and fi-om 0» to 90° latitude; the second quadrant 
extends from 0° to 1 80° longitude and from 0° to -90° latitude; the third quadrant extends 
from 0° to -180° longitude and from 0° to 90° latitude, and the four quadrant extends 
from 0° to 1 80° longitude and from 0° to -90° latitude. The second level of the quadtree 
can be conceptuaUzed as four smaller "squares". These four smaller squares are the four 
quadrants of the "square" associated with the first level. It should be noted that the 
portions of the earth's surface that are represented by these four smaller squares are not 
actually squares due to the curvature of the earth's surface. As such, the term "square- 
is used to aid in visualizing the quadtree. The third level of the quadtree represents 
sixteen "squares", four groups of four "squares". Each group of four "squares" represents 
all of the quadrants of one of the squares represented by the second level of the quadtree. 
So, for example, if one of the "squares" associated with the second level of the quadtree 
represented the portion of the earth's surface that includes North America, each of the 
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group of four "squares" at the third level that comprise the "square" at the second level 
that is would represent one of the quadrants of North America. It should be 
appreciated that the area of the earth's surface represented by a "square" at a level 
decreases as the level increases. For example, the area of the earth's surface represented 
5 by a "square" at the third level of the quadtree is considerably less than the area of the 
earth's surface represented by one of the "squares" at the second level of the quadtree. 
A quadtree representation of the earth's surface that includes 32 levels provides accuracy 
to within one centimeter. 

The quadtree structure is adapted to identify one or more areas of interest by 

1 0 associating with each square at the highest level, i.e., the smallest squares, a flag or other 
indication that the square is part of the area of interest. For example, if the quadtree 
representation of earth's surface has been extended to 10 levels and the area of interest 
is Los Angeles, a certain number of the squares at level 10 will be identified or "flagged" 
as representing Los Angeles, 

15 In one embodiment, the portions of the quadtree structure that have been 

"flagged" ( i.e., belong to the area of interest) are reviewed to determine if the quadtree 
structure can be condensed. This review involves assessing whether each "square" of 
a group of four "squares" that represent a larger "square" of a preceding level of the 
quadtree is associated with the area of interest. If each of these "squares" is associated 

20 with the area of interest, the "flag" can be moved to the larger "square" and the smaller 
"squares" can be deleted from the quadtree. For instance, if all four "squares" of a group 
of four "squares" at level-10 are "flagged" as being associated with Los Angeles, it is 
sufficient to associate the "flag" with the level-9 "square" that encompasses the four 
level- 1 0 squares. If the "flag" is moved to a lower level square, the amount of memory 

25 required to store the quadtree is reduced. Further, a quicker determination of whether the 
location associated with the wireless station is within the area of interest is possible in 
certain situations. To continue with the same example, if the location associated with the 
wireless station is in area represented by the level-9 "square" to which the "flag" has 
been moved from the four level-10 "squares", the determination will be made sooner 

30 because the flag associated with the level-9 "square" will be detected sooner than a flag 
associated with a level-10 "square". 
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Also associated with each "square" is a location, which is typically expressed in 
tenns of latitude and longitude. The location is nonnally the center of the square. 
Advantageously, by using a quadtree that represents the entire surface of the earth, the 
location associated with each of the "squares" of the quadtree does not have to be stored. 
5 Rather, it can be quickly calculated. To elaborate, the center of the level- 1 "square" that 
is representative of the earth's surface is at 0° longitude and 0° latitude. Further, the 
longitude of the level-1 "square" extends from -1 80° to +180°, and the latitude from -90° 
to +90°. The longitude of the centers of the level-2 "squares" can be determined using 
a lookup table and the direction of the square Srom the location associated with the level- 
10 1 square. For instance, with respect to the level-2 square that is northwest of the location 
of the level-1 square, the lookup table would indicate that the longitude value for a level- 
2 square is 90° and the "west" portion of the direction means that the longitude of the 
northwest square is -90°. Similarly, the latitude value obtained from the lookup table 
would be 45° and "north" portion of the direction means that the latitude is +45°. This 

15 concept is extended to higher levels of the quadtree by simply adding the result of the 
lookup table query and sign designation to the appropriate coordinate of die lower level 
square. For instance, with respect to the level-3 square that is northeast of the location 
(-90° long., +45° lat.) of the leveI-2 square, the lookup table would indicate that a 
latitude value of 22.5° is appropriate and the "north" portion of the direction would 

20 dictate that a latitude of +22.5° should be added to the latitude associated with the level-2 
square to produce a latitude of 67.5°. 

With a quadtree structure constructed according to the foregoing, the present 
invention provides the abihty to determine whether the location associated with a 
wireless unit is within an area of interest. This determination is accomplished by initially 

25 comparing the location associated with the wireless unit to the location associated with 
the square of the first level. Based on this comparison, the quadrant of the first level 
square in which the location associated with the wireless station is found can be 
determined. For example, if the location associated with the wireless station is in Los 
Angeles and the square represented by the first level covered the entire earth, the 

30 comparison would show that the location of the wireless unit was in the northwest 
quadrant of the square. This determination is subsequently used to point to the smaller 
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square represented at the second level quadtree that will be subject to the same 
comparison and to calculate the location associated with this smaller square. To continue 
with the example, the determination at the first level would point to the second level 
square that contained Los Angeles, i.e., the northwest quadrant of the earth. At this point, 
5 the location associated with this second level square is calculated and compared with the 
location associated with the wireless imit to determine which one of the quadrants of the 
northwest quadrant contains the location associated with the wireless unit. This process 
continues until a square is reached that indicates that location is either in an area of 
interest or it is not. If a "flag" is associated with this square, then the location associated 

10 with the wireless station is within the area of interest. The absence of a "flag" and any 
pointers to squares at a higher level indicates that the location of the wireless unit is not 
in an area of interest. 

The present invention also provides the ability to build a quadtree data structure 
suitable for use in determining whether a location associated with a wireless unit is within 

15 an area of interest. The process is typically initiated by a customer of a wireless service 
provider giving the service provider a map that identifies one or more areas of interest. 
For instance, the municipality responsible for responding to "911" calls may station 
emergency response teams at various locations and make each of these teams responsible 
for a particular area of the city. Once the area or areas of interest have been identified, 

20 a computer map is generated that defines the boundary of each area as a series of lines 
connected to one another to fonm a polygon. At this point, a determination is made as to 
whether the quadrants that form the square represented by the first level of the quadtree 
are at least partially contained within the polygon. This is done by determining if at least 
one boundary line of the polygon intersects an edge of the quadrant. For each quadrant 

25 with an edge that is intersected by a boundary line, the process is repeated at the second 
level of the quadtree. This process continues until all the squares represented by the 
highest level of the quadtree (i.e., the smallest squares) that have an edge that is 
intersected by a boundary line of the polygon have been identified. At this point, a 
decision has to be made whether the squares that are not wholly within the polygon are 

30 to be identified ("flagged") as being associated with the area of interest. One basis for 
making this decision is to include the square if the center of the square is within the 



-24- 



wo 01/33825 



PCTAJSOO/30479 



10 



polygon and otherwise to exclude the square.. Other bases for making this decision are, 
however, feasible. At this juncture all of the squares represented at the highest level that 
are going to be associated with an area of interest have been identified and the quadtree 
can be used in a system for detennining if the location associated with a wireless station 
is within an area of interest. 

In certain instances the quadtree can be condensed, as previously discussed. 
Namely, if all of the squares of a group of four squares that constitute the quadrants of 
a square at the next highest level are "flagged", the square at the next highest level can 
be flagged and the four squares deleted fiom the quadtree. The condensation process 
begins at the highest level of the quadtree and sequentially proceeds through lower levels. 
Thecondensation process tenninates when a level does not have four squares that satisfy 
the noted condition. A quadtree that has been condensed has lower storage requirements 
relative to a quadtree that has not been condensed. Further, a condensed quadtree will 
increase, in certain situations, the speed at which the determination is made of whether 
1 5 the location associated with the wireless unit is within the area of interest. 

Also provided by the present invention is the ability to update a quadtree data 
structure used in making the above-noted determination with little effect upon the 
telecommunication system in which quadtree structure is implemented. Updating 
involves assessing the consequences of the proposed changes to the areas of interest. For 
example, the reduction in size of an area of interest is likely to require that the "fiags" 
associated with one or more of the squares represented at a level of the quadtree be 
deleted. Once this assessment has been made, a replacement for the portion of the 
quadtree data structure that requires changes is constructed and inserted into the quadtree 
data structure. After the replacement has been inserted, the old portion of the quadtree 
data structure is deleted. Advantageously, since the replacement portion is inserted 
before the portion being replaced is deleted, the ability to make a determination of 
whether a location associated with a wireless unit is in an area of interest is substantially 
unaffected. Furthermore, the insertion and deletion process can be accomplished in a 
very quickly so as not to disturb the telecommunication system that is implementing the 
30 process. 
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The foregoing method for determining if a location is within an area of interest 
is preferably carried out on a computer system. The computer system includes: (1) a 
memory that contains (a) a program that performs the operations necessary to determine 
if the location associated with a wireless unit is within a predetermined area and (b) at 
5 least a portion of the quadtree data structure described above; (2) a processor that 
executes the program and, in so doing, accesses the quadtree data structure stored in 
memory; and (3) an input/output structure for receiving the locational data associated 
with the wireless unit and transmitting an indication of whether or not the location 
associated with the wireless unit is within an area of interest. In one embodiment, the 
10 computer system also includes a disk drive for storing all or a portion of the quadtree data 
structure. This permits portions of the quadtree data structure to be brought into memory 
as needed by the processor in an operation that is typically referred to as "caching," 
Consequently, the caching ability permits implementation on a computer system in 
which a limited amount of memory can be dedicated to the quadtree data structuure, 

15 

d) Closest Location 

For many applications, it may be desirable to identify the closest service provider 
location such as the closest hotel meeting the subscriber's requirements, the closest taxi, 
closest restaurant, etc. In such cases, location information for various service providers 

20 or outlets as well as any subscriber preferences can be stored in a database. Upon 
receiving a service request and associated subscriber location information, the location 
based services application can iteratively compare the subscriber location to the locations 
of acceptable service providers or outlets. Such comparisons can involve simple 
geometric distance calculations or may take network topology into account as described 

25 below. 

e) Network Topology 

For some applications, it may be desirable to consider network topology rather 
than merely abstract geography. Network topology may involve local street grid and 
30 traffic flow information, local transportation line information, or other network 
information affecting travel. For example, such network topology maybe used to provide 
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driving instructions or to identify a closest service provider in tenns of driving time or 
driving dzstance. In the latter regard, a location based services appHcation may execute 
*e following steps as illustrated in Fig. 6: 1) recdve (602) a location of subscriber 2) 
associate (604) the location with a network location (e.g., a street location); 3) acJess 
(606) a database of network topology information, for example, describing a local street 

gndmcIudmginformationregardmgone-waystreets.exitr^psandthelike;4)establish 

(608) travelconstraintsbasedonthenetwork topology; 5)access(610)serviceprovider 
location information and associate such locations with network locations as required for 
example, using a GIS system (this may be done at the time the location information is 

enteredmtothedatabaseoratsomeothertimepriortoreceivingthesubscriberlocation)- 
and .6) ueratively derive (612) driving paths between the subscriber and the various 
service providers based on the network topology information, subscriber location 
mformatron and service provider location information. The selection of an appropnate 
servrce provider/driving path may further take into account historical or current traffic 
flow conditions relative to the driving paths under consideration. 

It will be appreciated that many other types of spatial algorithms are possible and 
can be supported in accordance with the present invention. In addition, it will be 
appreciated that the operation of various location based services applications may entail 

accessmgGISapphcations, forexample. GIS based information that hasbeenpreviously 
stored. As noted above, such GIS applications are operative for interpreting a geographic 
location m relation to mapping information such as street address infomiation, street 

network topology and service zone maps. Thus, for example, street address infonnation 
may be converted to geographical coordinate infomiation or vice versa. One such GIS 

applicationismarketedbySignalSoftCorp.ofBoulder.ColoradounderthenameMAPS. 

The GIS application may be accessed . for example, to convert a subscriber 
location (e.g., provided to define a home billing zone of a location-based billmo 
application) provided by way of a street location into geographical coordinates, or to 
convert a service provider location or service area boundary provided m terms of 
street/address infomiation into geographic coordinate infomiation for purposes of a 
closest location, area of interest or other analysis. In such cases, it may be desirable to 
access GIS provisioned data for a location comparison or other transaction. In 
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accordance with the present invention, this, can be accomplished as illustrated in Fig. 7 
by: 1 ) obtaining (702) input location information for use by a location based services 
application; 2) identifying (704) at least a portion of the input location information for 
inteipretation using GIS data; 3) accessing (706) a GIS application for interpretation of 

5 the identified portion of the location information; 4) receiving (708) GIS interpreted data 
from the GIS application; 5) receiving (710) a location based services request; and 6) 
processing the service request based on the GIS interpreted data. In this regard, the 
service request may be processed in accordance with the nature of the specific location 
based service application such as described above, for example, to determine whether a 

10 mobile unit is within an area of interest, to identify a service provider, or to provide 
location information such as traffic or weather conditions. The GIS application may be 
used periodically, for example, in connection with updating operating zones of a location 
based services application and may be accessed at or near the time of a service request: 
To facilitate such cooperation beuveen the location based services application and GIS 

1 5 application, at least portions of the GIS application and services application, or ftinctional 
units provided as separate applications (such as a Location Manager for supporting 
location based services applications) maybe colocated on a common network platform 
or node such as a platform associated with a switch of a wireless network. 

20 5. Layered Architecture and Toolkits 

The present invention facilitates the development and operation of a variety of 
different types of location based service applications by providing certain standardized 
components that can support multiple applications. These components may be provided 
as separate toolkits to application developers and/or may be made available via a public 

25 or private network for access by developers and applications. Such standardization may 
involve: 1 ) an understanding of the different types of spatial analysis that may be desired 
for various types of location based services applications; 2) an identification of a set of 
spatial algorithms for supporting the applications; 3) an understanding of the different 
types of positional data and data formats that may be available fi-om LFE*s or other 

30 location finding technologies; 4) an understanding of the different requirements or 
priorities that different applications may have regarding, for example, accuracy or 
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■imclmess of locaUon in^^n; and 5) ,he p^vsicn of a sys,em or layered 
^..ctoe for interfacing location based services appiicanons wiu. available locadon 
find„,g .ectaologies without re<,uinng ,ha, ,he subject appUcations and location «„ding 

-tao'^S-bespecif.callyadap.edforoneanotherandforp^vidingaccesstoavane.y 
of spatial algoritluns for a variety of applications such flta, the need for cusUKn 

algorithms is reduced. 

Fig.8showsalayered architecture 800 forimplementing location based semces 
apphcanons using components that are connx^on to multipleapplication^^ 
of lustration, the architecture is divided into an applications layer 802, a middleware 
layer 804 and a core class libraries layer 806. Generally, the application in the 
applications layer (802) can call or access the middleware components to .mplement 
specific functions, and the middleware components access the core class hbraries to 
unplement such functions. It will be appreciated that the charactenzation of a particular 
element, for example, as an application of the apphcations layer or a middleware 
component can vary depending on the specfic context. However. F,g. 8 illustrates an 
important advantage of the present mvent.on; namely, that through standardization 
common resources can be used to support multiple applications, even though those' 

apphcatronsmayhavedifferentobjectivesanddifferentrequirementsregardinglocation 
data and the like. In particular, the spatial algorithms operate independent of any 

particular apphcation. That., thealgorithmscanreceivelocationinformationexpressed 
m a standard format and perform spatial analyses such as descdbed above without 
requ.nng knowledge concerning the type of application being implemented. Moreover 

astandard interface isprovidedforaccessingthespatial algorithms and othertoolsso that 
developers can write applications that arecompatiblewith the tools and/orthat can access 

thetoolsusingtheknowninterface.Accordingly,theiliustmedlayeredarchitecture800 
facrhtates apphcation development and implementation. In th.s regard, the illustrated 
middleware 804 and certain core class libraries 806 may be provided as separate toolkits 
to developers. 

As shown in Fig. 8 the illustrated architecture 800 includes multiple location 

based services appUcat,onsintheapplicat,onslayer802.Forexample, such applications 
may mclude a location based b.lhng application 808, a 911 application 810 a hotel 
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locator application 812 and a driving instructions application 814. Each of these 
applications may access one or more of the middleware components. The illustrated 
middleware components include a Location Manager component 816, a spatial 
algorithms library 8 1 8 and a GIS application 820. For example, any of the location based 
5 services programs may access the Location Manager 8 1 6 to request mobile unit location 
information and to specify certain parameters for the information such as accuracy or 
timeliness of the information. Similarly, any of the location based services applications 
may access the spatial algorithms 818 based on the objectives of the application. In this 
regard, the location based billing and 91 1 applications may access point-in-polygon, 
10 point-in-area, circle overlap or quadtree logic and the hotel locator and driving 
instructions applications may access closest location logic for use in conjunction with 
data provisioned by the GIS application 820. Any of the location based services 
applications may access the GIS application to correlate street address or other mapping 
data to geographical coordinates data, or vice versa. 
15 The middleware components may access any of various core class libraries 806 

to implement the requested functions. These core class libraries 806 may include core 
mathematical routines 822 for use in implementing the spatial algorithms 818, 
network/service area databases 824, a database of cached or otherwise stored "current" 
mobile unit location information 826, quadtree data structures 828, network topology 
20 databases 830 etc. 

. Fig. 9 illustrates a process for developing a location based services application 
using the architecture of Fig, 8 and/or a toolkit in accordance with the present invention. 
The process is initiated by determining (902) the application objectives. For example, 
the developer may wish to develop a location based billing, 911, driving instructions or 
25 other application such as discussed above or any other services application making use 
of mobile unit location. Based on the application objectives, the developer may then 
identify (904) a spatial algorithm type appropriate for the application. For example, for 
a location based billing or 911 application, a developer may determine that a point-in- 
polygon or point-m-area algorithm is appropriate depending, for example, on the nature 
30 of the dispatcher service areas involved. The developer can then access (906) the spatial 
algorithm library to select an appropriate algorithm. In this regard, the developer may 
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simply acquire a spatial algorithm tool from an available toolkit. Alternatively the 
applicatior. may be linked to the tool via a public or private network. Similarly the 
developer may access (908) any other appropriate tools such as a GIS application or the 
like. 

5 Once the developer has identified and selected the appropriate tools to be 

accessedbythelocationbasedservices application, anyrelevantapplicationspecificdata 
may be ported (910) to the tool and/or the associated core class libr^es. For example 
m the case of a location based billing application, infonnation regarding the relevant' 
bUImg zones may need to be ported for use by the spatial algorithms and/or any 

0 mfonnation regarding the timeliness or accuracy of the required location data may need 
tobeportedtoalocationmanagercomponent. ITie application may then be ported (91 2) 
to the OLTP environment. For example, a location sensitive billing apphcation may be 
resident, at least in part, on a platform associated with a switch so as to enable near real 
time access to location finding equipment inputs, phone call data and other data as 

5 required. The application can then be implemented (914) by activating the program to 

receiveservicerequestsorotherinputsforinitiatingalocationbased services transaction. 

Fig. lOillusiratesaprocessforimplementingalocationbased services application 
using the architecture of Fig. 8. For purposes of illustration. Fig. 10 illustrates the 
operation of a location based services application for identifying the closest hotel to a 
) subscnber meeting certain criteria, determining a driving path for reaching the identified 
hotel, and providing driving instructions to the subscriber. It will be appreciated that the 
location of the various process steps relative to the system architecture may be varied. 
In addition, the sequence of steps may be varied. For example, rather than identifying a 
closest hotel and then determining a driving path, the location of hotels may be 
considered concunrently with network topology information in order to identify the hotel 
having the shortest driving path or driving time relative to the location of the subscnber. 
In addition, although a specific application is shown for purposes of illustration, it will 
be appreciated that a great variety of applications may be implemented using the 
' architecture of Fig. 8. 

Referring to Fig. 10, the illustrated process is initiated by establishing (1002) a 

hotellocatorapplication andreceivingaservice request. Forexamplctheservice request 
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may indicate that the subscriber wishes to obtain driving instructions to the closest hotel 
relative to a current location of the subscriber. The service request may be entered, for 
example, by entering "*HOTEL" on the keyboard of a wireless telephone. 

In response to the service request, the hotel locator application may access ( 1 004) 

5 a location manager tool which is conceptualized as part of the middleware layer for 
purposes of Fig. 10. In this regard, the signal transmitted to the location manager may 
identify the subscriber and may also specify certain information regarding the accuracy 
and timeliness of the location data that is desired. For example, the hotel locator 
application may require very recent data regarding the subscriber location in order to 

1 0 properly identify the closest hotel. Accordingly, the location manager may access ( 1 006) 
mobile unit location information by querying any available finding equipment in order 
10 obtain current location data. Alternatively, the location manager may scan a location 
cache to determine whether timely and accurate location data is available. In other 
implementations, the location manager may identify the location of the wireless unit by 

15 noting the location of a cell or cell sector from which the service request was placed. 
Once the location manager obtains appropriate location information for the identified 
subscriber, the location is reported to and received ( 1 008) by the hotel locator application. 
In this regard, implementation of the present invention is facilitated by the standardized 
data format and application interface of the Location Manger System as described in 

20 copending application serial numbers 60/106,816 and 09/396,235. 

Upon receiving the location data from the location manager, the hotel locator 
application may access (1010) the spatial algorithms library of the middleware layer in 
order to select a closest location algorithm. In conjunction with implementing this 
algorithm, the associated spatial algorithm logic may access (1012) various databases or 

25 libraries of the core class layer. For example, a database of GIS provisioned data 
regarding hotel locations may be accessed to identify candidate hotels. In addition, a user 
preferences database may be accessed in order to identify any preferences that the 
subscriber may have previously entered regarding hotel accommodations. Moreover, the 
spatial algorithms logic may access certain core mathematical routines for implementing 

30 the requested spatial algorithm. Once the closest location has thereby been identified. 
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location information can be transmitted to and received (1014) by the hotel locator 
application. 

In the illustrated application, it is desired to provide driving instructions to the 
identified hotel. Accordingly, upon receiving the closest location information, the hotel 
5 locator application may access (1016) a network topology database for driving 
information. Among other things, such a database may include infonnation regarding 
street locations and traffic flow data. The hotel locator application can use this network 
topology information to iteratively investigate alternative driving paths so as to select a 
shortest or quickest driving path to reach the identified hotel. 

1 0 - Upon receiving this driving information, the hotel locator application can transmit 

driving instructions (1020) to the subscriber. These driving instructions maybe reported 
to the subscriber, for example, audibly or visibly. For example, the driving instructions 
may be automatically displayed on a display of the subscribers telephone using a paging 
feature. Alternatively, a voice channel may be established with the subscribers telephone 

1 5 such that a recorded message can be played. 

While various embodiments of the present invention have been described in 
detail, it is apparent that further modifications and adaptations of the invention will occur 
to those skilled in the art. However, it is to be expressly understood that such 
modifications and adaptations are within the spirit and scope of the present invention. 

20 
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What Is Claimed Is : 

1 . A method for use in providing location related information in a wireless 
network, comprising the steps of: 

storing service information defining service locations relative to geographic 
5 infomiation; 

obtaining input location infomiation regarding a location of a wireless unit based 
on signals transmitted within said wireless network including said wireless unit; 

accessing a library including logic for implementing a plurality of spatial 
algorithms, wherein each of said spatial algorithms is useful for performing a location 
1 0 comparison between first geographic information and second geographic information; 
selecting one of said plurality of spatial algorithms; 

first using said selected spatial algorithm relative to said stored service 
information and said obtained input infomiation to identify a service location for said 
wireless unit; and 

1 5 second using said identified service location in connection with providing services 

for a user of said wireless unit, wherein said identified service location can be used for 
one of providing desired services and recording business information based on the 
location of said wireless unit. 

2. A method as set forth in Claim 1, wherein said step of storing service 
20 information comprises storing geographical coordinates of a location of a service 

provider. 

3. A method as set forth in Claim I, wherein said step of storing service 
information comprises storing geographical coordinate information defining operating 
zones of a location based services application. 

25 4. A method as set forth in Claim 1, wherein said step of storing service 

information comprises receiving an input and processing said input using a GIS 
application to obtain said service information. 

5. A method as set forth in Claim 1, wherein said step of obtaining input 
location information comprises receiving information regarding a subdivision of said 

30 wireless network in which said wireless unit is located. 
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6. A method as set forth in Claim 1, wherein said step of obtaining input 
location information comprises receiving coordinate information from location finding 
equipment. 

7. Amethod as set forth in Claim 1, wherein said step of selecting comprises 
calling logic forcomparingsaidlocationofsaidwirelessunittoalocationofan operating 



5 



zone. 



8. A method as set forthin Claim 1, wherein said step of selecting comprises 
calling logic for determiningadistancebetween said wireless imit and a service location. 

^- ^'"^*°<^assetforthinClaiml,whereinsaidstepofselectingcomprises 
1 0 calling logic for comparing a first area to a second area for overlap. 

10. A method as set forth in Claim 1, wherein said step of first using 
comprises identifying an operating zone of a location based services application based 
on said location of said wireless unit. 

11. A method as set forth in Claim 1, wherein said step of first using 
1 5 comprises identi fying a local location of a service provider. 

12. A method as set forth in Claim 1, wherein said step of second using 
comprises routing a call based on said identified service location. 

13. A method as set forth in Claim 1, wherein said step of second using 
comprises establishing a call rating value based on said service location. 

A "'^'hod as set forth in Claim 1, wherein said step of second using 
comprises providing one of local service inforaiation and local traffic information via 
said wireless unit. 

~ 15. A method for use in providing location related infomiation in a wireless 
network, comprising the steps of; 

25 providing a location based services application for use in a wireless network, said 

location based services application bemg operative to make service related 
determinations based on locations of wireless units in relation to defined service 
locations; 

receiving an input regarding a geographic location for use by said location based 
30 services application in makmg a first seivice related determination, said input comprising 
a first one of network topology information and coordinate information wherein 
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coordinate inforrnation relates to geographical coordinates and network topology 
information relates to a predefined reference location of a network; 

providing a geographic information system (GIS) application for making 
correlations between geographical coordinates and network information; 
5 establishing conunimication between a platform running said location based 

services application and said GIS application such that said GIS application can be used 
to express said input in terms that can be readily handled by said location-based services 
application; 

first using said input and said GIS application to derive processed location 
10 information, said processed location information comprising a second one of said 

network information and said coordinate information different from said first one; and 
second using said location based services application and said second one of said 

network information and said coordinate information to provide location based services 

for a user of a wireless unit. 
15 16. A method as set forth in Claim 15, wherein said step of receiving an input 

comprises receiving network service area information regarding said defined service 

areas wherein said network service area information includes said network information, 

and said step of first using comprises employing said GIS application to derive said 

coordinate information based on said network infomiation, wherein said coordinate 
20 information is provisioned for said location based services application based on said 

network service area information. 

1 7. A method as set forth in Claim 16, wherein said step of receiving network 

service area information comprises receiving information expressed in terms of street 

network. 

25 1 8, A method as set forth in Claim 1 6, wherein said step of receiving network 

service area information comprises receiving information expressed in terms of 

subdivisions of said wireless network. 

1 9. A method for use in providing location related information in a wireless 

network, comprising the steps of: 
30 storing reference information defining a reference geometry relative to geographic 

information, said reference geometry including a number of reference zones; 
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Storing operating zone infonnation defining a number of operating zones relative 
to geographic information, each of said operating zones comprising an area for use by a 
location based services application; 

obtaining input location information regarding a location of a wireless unit based 
5 on signals transmitted within said wireless networic including said wireless unit; 

based on said input information regarding said location of said wireless unit, 
using both the reference information and the operating zone information to identify ari 
operating zone of said wireless unit for use by said location based services application; 



10 



15 



and 



• using said identified operating zone in comiection with providing services for a 
user of said wireless unit, wherein said identified operating zone can be used for one of 
providing desired services and recording business information based on the location of 
said wireless unit. 

20. A method as set forth in Claim 19, wherein said step of storing reference 
information comprises storing information defining a number of wireless network 
subdivisions in terms of geographic coordinates. 

21 . A method as set forth in Claim 1 9, wherein said step of storing reference 

inforniationcomprisesstoringinformationdefminganumberofpixelsofaquadtreedata 
structure, 

20 22. A method as set forth in Claim 19, wherein said step of storing operating 

zone information comprises storing infomiation defining a home zone of a subscriber for 
use by a location-based billing applicauon. 

r 23. A method as set forth in Claim 19, wherein said step of storing operating 
zone information comprises storing infonmation defining service zones of a serx'ice 

25 provider. 

24. A method as set forth in Claim 19, wherem aid step of obtaining 
comprises receiving one of subdivision information regarding a wireless network 
subdivision in which said wireless umt is located and location information fi-om location 
finding equipment. 

^ '"^^^^o^ set forth in Claim 19, wherein said step of using both the 
reference information and the operating zone information comprises expressing the 
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operating zone information in terms of the reference geometry i8n order to facilitate a 
location comparison as between the location of the wireless unit and the operating zones. 

26. A method as set forth in Claim 19, wherein said step of using said 
identified operating zone corpses routing a call to or from said wireless unit based on said 

5 identified operating zone, 

27. A method as set forth in Claim 19, wherein said step of using said 
identified operating zone comprises establishing a call rating value for a call by said 
wireless unit. 

28. A method as set forth in Claim 19, wherein said step of using said 
1 0 identified operating zone comprises providing information to said wireless unit based on 

said identified operating zone. 

29. A method for use in providing location related information in a wireless 
network, comprising the steps of: 

providing a library including logic for implementing a plurality of spatial 
1 5 algorithms wherein each of said spatial algorithms is useful for performing a location 
comparison between first geographic information and second geographic information; 

first providing access to said library in connection with a first wireless location 
based services application such that said first wireless location based services application 
can access a first of said plurality of spatial algorithms for use in locating first wireless 
20 units so as to provide a first type of wireless location based services; and 

second providing access to said library in connection with a second wireless 
location based services application such that said second wireless location based services 
application can access a second of plurality of spafial algorithms for use in locating 
second wireless units so as to provide a second type of wireless location based services. 
25 30. A method as set forth in Claim 29, wherein said step of providing a library 

comprises developing said plurality of spatial algorithms that operate independent of any 
specific application. 

31. A method as set forth in Claim 29, wherein said plurality of spatial 
algorithms includes at least two of the following algorithm types: point in area, circle 
30 overlap and closest location. 
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32. A method as set forth in Claim 29, wherein said step of first providing 
access comprises providing a toolkit to a developer for use in developing said first 
wireless location based services application. 

33. A method as set forth in Claim 29, wherein said step of second providing 

5 <^o™Prisesprovidingastandardinterfaceforaccessingsaidpluralityofalgorithmsduring 
use of said second wireless location based services application. 

34. A method as set forth in Claim 29. wherein aid fii^t wireless location 
based services application comprises an emergency services application and said second 
wireless location based services application comprises one of a location based billing 

1 0 application and a local services application. 
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